<template>
  <div id="outStocks">
    <!-- 面包导航 -->
    <el-breadcrumb separator="/" style="padding-left:10px;padding-bottom:10px;font-size:12px;">
      <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
      <el-breadcrumb-item>物资管理</el-breadcrumb-item>
      <el-breadcrumb-item>出库记录</el-breadcrumb-item>
    </el-breadcrumb>

    <!-- 卡片部分-->
    <el-card>
      <!--搜索部分-->
      <el-form size="mini" :inline="true" :model="queryMap" class="demo-form-inline">
        <el-form-item label="发放单号">
          <el-input v-model="queryMap.outNum" placeholder="发放单号"></el-input>
        </el-form-item>
        <el-form-item label="发放类型">
          <el-select v-model="queryMap.type" placeholder="发放类型">
            <el-option label="全部类型" value=""></el-option>
            <el-option label="政府领取" value="0"></el-option>
            <el-option label="医院领取" value="1"></el-option>
            <el-option label="小区领取" value="2"></el-option>
            <el-option label="个人领取" value="3"></el-option>
            <el-option label="其他领取" value="4"></el-option>
          </el-select>
        </el-form-item>
        <el-form-item>
          <el-select v-model="queryMap.status" placeholder="请选择状态">
            <el-option label="已发放" :value="0"></el-option>
            <el-option label="回收站" :value="1"></el-option>
            <el-option label="待审核" :value="2"></el-option>
          </el-select>
        </el-form-item>
        <el-form-item>
          <el-button type="primary" @click="search">查询</el-button>
          <el-button @click="reset">重置</el-button>
        </el-form-item>
        <el-form-item>
          <router-link to="/OutStocks/publishStocks">
            <el-button type="success">
              发放
            </el-button>
          </router-link>
        </el-form-item>
      </el-form>

      <!--数据表格-->
      <el-table
        size="mini"
        border
        :data="tableData"
        style="width: 100%;height: 450px;">
        <el-table-column label="#" prop="id" width="50"></el-table-column>
        <el-table-column prop="outNum" :show-overflow-tooltip='true' label="发放单号" width="180"></el-table-column>
        <el-table-column prop="type" label="发放类型" width="100">
          <template slot-scope="scope">
            <el-tag effect="plain" size="mini" type="success" v-if="scope.row.type===0">政府领取</el-tag>
            <el-tag effect="plain" size="mini" type="danger" v-else-if="scope.row.type===1">医院领取</el-tag>
            <el-tag effect="plain" size="mini" type="warning" v-else-if="scope.row.type===2">小区领取</el-tag>
            <el-tag effect="plain" size="mini" type="info" v-else-if="scope.row.type===3">个人领取</el-tag>
            <el-tag effect="plain" size="mini" v-else-if="scope.row.type===4">其他领取</el-tag>
          </template>
        </el-table-column>
        <el-table-column prop="priority" label="紧急程度" width="180">
          <template slot-scope="scope">
            <el-rate
              :disabled="true"
              v-model="scope.row.priority"
              show-text
              :texts="['不急','常规','紧急','特急','超急']"
            >
            </el-rate>
          </template>
        </el-table-column>
        <el-table-column prop="name" label="发放地点" width="150"></el-table-column>
        <el-table-column prop="productNumber" label="总数" width="80"></el-table-column>
        <el-table-column prop="phone" label="联系方式" width="120"></el-table-column>
        <el-table-column prop="status" label="状态" width="100">
          <template slot-scope="scope">
            <el-tag size="mini" type="danger" effect="plain" v-if="scope.row.status==1">回收</el-tag>
            <el-tag size="mini" effect="plain" v-if="scope.row.status==0">已放</el-tag>
            <el-tag size="mini" effect="plain" type="warning" v-if="scope.row.status==2">审核中</el-tag>
          </template>
        </el-table-column>
        <el-table-column prop="operator" label="操作员" width="150"></el-table-column>
        <el-table-column prop="createTime" label="发放时间" width="200px;"></el-table-column>
        <el-table-column label="操作" fixed="right" width="200">
          <template slot-scope="scope">
            <el-button icon="el-icon-view" type="text" size="small" @click="detail(scope.row.id)">明细</el-button>
            <!--给操作员使用的按钮-->
            <span v-if="scope.row.status==0">
                <el-popconfirm
                  @confirm="remove(scope.row.id)"
                  style="margin-left: 20px;"
                  confirmButtonText='好的'
                  cancelButtonText='不用了'
                  icon="el-icon-info"
                  iconColor="red"
                  title="这是一段内容确定移入回收站吗？"
                >
                <el-button type="text" slot="reference" size="mini" icon="el-icon-s-operation">回收站</el-button>
                </el-popconfirm>
            </span>
            <!--给操作员使用的按钮(回收站)-->
            <span v-if="scope.row.status==1">
               <el-popconfirm
                 @confirm="back(scope.row.id)"
                 style="margin-left:10px;"
                 confirmButtonText='好的'
                 cancelButtonText='不用了'
                 icon="el-icon-info"
                 iconColor="green"
                 title="这是一段内容确定恢复数据吗？"
               >
                 <el-button type="text" slot="reference" size="mini" icon="el-icon-s-operation">还原</el-button>
               </el-popconfirm>
                <el-popconfirm
                  style="margin-left:20px;"
                  @confirm="del(scope.row.id)"
                  title="这是一段内容确定删除吗？"
                >
                  <el-button type="text" slot="reference" size="small" icon="el-icon-delete">删除</el-button>
                </el-popconfirm>
            </span>

            <!-- 给审核员使用的按钮-->
            <span v-if="scope.row.status==2">
              <el-popconfirm
                style="margin-left:20px;"
                @confirm="publish(scope.row.id)"
                title="审核通过后库存将更新,是否通过"
              >
                <el-button type="text" slot="reference" size="small" icon="el-icon-refresh">通过</el-button>
              </el-popconfirm>
              <el-popconfirm
                style="margin-left:20px;"
                @confirm="del(scope.row.id)"
                title="这是一段内容确定删除吗？"
              >
                <el-button type="text" slot="reference" size="small" icon="el-icon-delete">删除</el-button>
              </el-popconfirm>
            </span>
          </template>
        </el-table-column>
      </el-table>

      <!--表格分页-->
      <el-pagination
        style="margin-top:20px;"
        background
        @size-change="handleSizeChange"
        @current-change="handleCurrentChange"
        :current-page="queryMap.pageNum"
        :page-sizes="[10, 20, 30, 40]"
        :page-size="queryMap.pageSize"
        layout="total, sizes, prev, pager, next, jumper"
        :total="total"
      ></el-pagination>

      <!-- 发放明细 -->
      <el-dialog title="发放明细" :visible.sync="dialogVisible" @close="closeDetail" width="60%">
        <!--消费者信息-->
        <el-card class="box-card" style="margin-bottom: 10px;">
          <div class="text item">
            <el-row :gutter="20">
              <el-col :span="6">
                <div class="grid-content bg-purple">
                  <span style="font-size: 11px;color: #303030;">省区市:</span> &nbsp;<el-tag size="mini">
                  {{consumer.address}}
                </el-tag>
                </div>
              </el-col>
              <el-col :span="6">
                <div class="grid-content bg-purple">
                  <span style="font-size: 11px;color: #303030;">具体位置:</span> &nbsp;<el-tag size="mini">
                  {{consumer.name}}
                </el-tag>
                </div>
              </el-col>
              <el-col :span="6">
                <div class="grid-content bg-purple">
                  <span style="font-size: 11px;color: #303030;">联系人 :</span> &nbsp;<el-tag size="mini">
                  {{consumer.contact}}
                </el-tag>
                </div>
              </el-col>
              <el-col :span="6">
                <div class="grid-content bg-purple">
                  <span style="font-size: 11px;color: #303030;">电话 : </span>&nbsp;<el-tag size="mini">
                  {{consumer.phone}}
                </el-tag>
                </div>
              </el-col>

            </el-row>
          </div>
        </el-card>

        <!--步骤条-->
        <el-steps simple v-if="pStatus==0" style="margin-left: 10px;margin-bottom: 5px;" :space="200" :active="3"
                  finish-status="success">
          <el-step title="提交发放单"></el-step>
          <el-step title="审核发放单"></el-step>
          <el-step title="成功发放"></el-step>
        </el-steps>
        <el-steps simple v-if="pStatus==2" style="margin-left: 10px;margin-bottom: 5px;" :space="200" :active="2"
                  finish-status="success">
          <el-step title="提交发放单"></el-step>
          <el-step title="审核发放单"></el-step>
          <el-step title="成功发放"></el-step>
        </el-steps>

        <!--明细表格-->
        <span>
        <template>
            <el-table height="260" max-height="350" border :data="detailTable" style="width: 100%">
              <el-table-column prop="name" label="名称"></el-table-column>
              <el-table-column :show-overflow-tooltip="true" prop="pnum" label="商品编号"></el-table-column>
               <el-table-column prop="model" label="规格"></el-table-column>
              <el-table-column
                prop="imageUrl"
                label="图片"
                align="center"
                width="150px"
                padding="0px"
              >
                <template slot-scope="scope">
                  <img
                    :src="'https://www.zykhome.club/'+scope.row.imageUrl"
                    alt
                    style="width: 30px;height:30px"
                  />
                </template>
              </el-table-column>
               <el-table-column prop="count" label="数量"></el-table-column>
                <el-table-column prop="unit" label="单位"></el-table-column>
            </el-table>
          <!--明细分页-->
            <el-pagination
              style="margin-top:20px;"
              background
              @current-change="handleDetailSizeChange"
              :current-page="this.pageNum"
              :page-size="3"
              layout="prev, pager, next,total"
              :total="this.detailTotal">
            </el-pagination>
        </template>
      </span>

      </el-dialog>
    </el-card>
  </div>
</template>

<script>
  export default {
    name: "OutStocks",
    data() {
      return {
        consumer: {},
        detailTotal: 0,
        detailTable: [],
        dialogVisible: false,
        pageNum: 1,
        total: 0,
        queryMap: {pageNum: 1, pageSize: 10, status: 0,},
        tableData: [],
        pStatus: '',//步骤flag
      }
    },
    methods: {
      /**
       *物资发放审核
       */
      async publish(id){
        const { data: res } = await this.$http.put("outStock/publish/"+id);
        if (res.code !== 200) {
          return this.$message.error("审核失败:"+res.msg);
        } else {
          await this.loadTableData();
          return this.$message.success("发放已审核通过");
        }
      },

      /**删除明细
       */
      async del(id) {
        const {data: res} = await this.$http.get("outStock/delete/" + id);
        if (res.code !== 200) {
          return this.$message.error("删除失败:" + res.msg);
        } else {
          await this.loadTableData();
          return this.$message.success("删除发放单记录成功");
        }
      },
      /**
       * 从回收站恢复
       */
      async back(id){
        const { data: res } = await this.$http.put("outStock/back/"+id);
        if (res.code !== 200) {
          return this.$message.error("从回收站恢复失败:"+res.msg);
        } else {
          await this.loadTableData();
          return this.$message.success("从回收站中已恢复");
        }
      },
      /**
       * 移除回收站
       */
      async remove(id) {
        const {data: res} = await this.$http.put("outStock/remove/" + id);
        if (res.code !== 200) {
          return this.$message.error("移入回收站失败:" + res.msg);
        } else {
          await this.loadTableData();
          return this.$message.success("移入回收站成功");
        }
      },
      /**
       * 关闭明细
       */
      closeDetail(){
        this.pageNum=1;
      },
      /**
       *  改变页码
       */
      handleDetailSizeChange(newSize) {
        this.pageNum = newSize;
        this.detail(this.detailId);
      },
      /**
       * 查看发放单明细
       */
      async detail(id) {
        this.detailId = id;
        const {data: res} = await this.$http.get("outStock/detail/" + id + "?pageNum=" + this.pageNum);
        if (res.code !== 200) {
          this.$message.error("获取明细失败:" + res.msg);
        } else {
          this.detailTable = res.data.itemVOS;
          this.detailTotal = res.data.total;
          this.consumer = res.data.consumerVO;
          this.pStatus = res.data.status;
          this.dialogVisible = true;
        }

      },
      /**
       * 重置查询表单
       */
      reset() {
        this.queryMap = {pageNum: 1, pageSize: 10, status: 0,};
      },
      //搜索
      search() {
        this.queryMap.pageNum = 1;
        this.loadTableData();
      },
      /**
       * 加载表格数据
       */
      async loadTableData() {
        const {data: res} = await this.$http.get("outStock/findOutStockList", {
          params: this.queryMap
        });
        if (res.code !== 200) {
          return this.$message.error("获取列表失败");
        } else {
          this.total = res.data.total;
          this.tableData = res.data.rows;
        }
      },
      /**
       * 改变页码
       */
      handleSizeChange(newSize) {
        this.queryMap.pageSize = newSize;
        this.loadTableData();
      },
      /**
       * 点击分页
       */
      handleCurrentChange(current) {
        this.queryMap.pageNum = current;
        this.loadTableData();
      },
    },
    created() {
      this.loadTableData()
    }
  }
</script>

<style scoped>

</style>
